28 网络管理之网卡配置

589次阅读
没有评论

共计 5170 个字符,预计需要花费 13 分钟才能阅读完成。

一. 网卡名字修改

1. 网卡命名规则

  • CentOS6 之前基于传统的命名方式如: eth1, eth0....
  • Centos7 提供了不同的命名规则,默认是基于固件、拓扑、位置信息来分配
  • 这样做的优点是命名是全自动的、可预知的,缺点是比 eth0 更难读, 比如 ens33

2. 网卡命名策略(了解)

28 网络管理之网卡配置

3. 配置网卡命名的方式

  • 修改网卡配置 文件 名称
⛅为了方便先进到目录, 改成你想要的名字
[root@shawn ~]#cd /etc/sysconfig/network-scripts/
[root@shawn network-scripts]#mv ifcfg-ens32 ifcfg-eth100
  • 修改网卡配置文件
⛅直接使用 "sed" 查找后替换掉
[root@shawn network-scripts]#sed -i "s/ens32/eth100/g" ifcfg-eth100

⛅或者进配置文件进行修改
[root@shawn network-scripts]#vim ifcfg-eth100
  • GRUB 添加 kernel 参数
⛅进入内核参数文件
[root@shawn network-scripts]#vim /etc/sysconfig/grub
⛅修改这一行,"100"
GRUB_CMDLINE_LINUX="rhgb quiet 'net.ifnames=100 biosdevname=100'"

⛅加载到引导分区, 生成菜单
[root@shawn network-scripts]#grub2-mkconfig -o /boot/grub2/grub.cfg

⛅重启系统生效, 再查看是否成功
[root@shawn network-scripts]#reboot
[root@shawn ~]#ifconfig
eth100: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500   #发现已经改变了

二. 基本网络配置

1. 查看网卡连接状态

⛅查看当前系统所连接的所有网卡 (我这里只有一个网卡, 所以显示一个)
[root@shawn ~]#lspci | grep -i eth
02:00.0 Ethernet controller: Intel Corporation 82545EM Gigabit Ethernet Controller (Copper) (rev 01)

⛅确认网卡是否连接(link ok 表示网卡能被识别, 并且接了有效的网线)
[root@shawn ~]#mii-tool eth100
eth100: negotiated 1000baseT-FD flow-control, link ok

⛅如果显示 "failed: .....", 则代表网线没连接等等

2.ifconfig 命令

⛅查看
ifconfig -a       #查看所有网卡信息
ifconfif eth100   #查看指定网卡信息

⛅配置, 添加子接口
ifconfig eth100 192.168.12.188/24    #临时设置 IP 和掩码(重启服务或系统都失效)
ifconfig eth100 192.168.12.188 netmask 255.255.255.0    #同上一样
ifconfig eth100:1 192.168.12.199/24  #配置子接口

⛅删除子接口
ifconfig eth100:1 down               #删除这个子接口
ifconfig eth100:1 del 192.168.12.199 #删除这个子接口

⛅开启与关闭网卡配置
ifconfig eth100 down/up              #不加载 / 加载这个网卡的配置文件
ifdown eth100 / ifup eth100          #不加载 / 加载这个网卡的配置文件

⛅设置网卡最大传输单元
ifconfig eth0 mtu 1500

⛅开启和关闭模式(了解)
ifconfig eth0 promisc              #开启繁杂模式
ifconfig eth0 -promisc             #关闭繁杂模式

ifconfig eth0 multicast            #开启多播
ifconfig eth0 -multicast           #关闭多播

ifconfig eth0 allmulti             #开启
ifconfig eth0 -allmulti            #关闭

⛅添加删除 "ipv6" 地址
ifconfig eth0 add 3ffe:3240:800:1005: :2/64
ifconfig eth0 del 3ffe:3240:800:1005: :2/64

3.ifconfig 查看结果解释

[root@shawn ~]#ifconfig
ens32: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
# [表示接口已启用] [表示主机支持广播] [表示接口在工作中] [表示主机支持多播] [mtu:1500 最大传输单元(字节)]
        inet 192.168.12.188  netmask 255.255.255.0  broadcast 192.168.12.255
        #IPV4 地址            #子网掩码               #广播地址
        inet6 fe80::20c:29ff:fe93:fdc8  prefixlen 64  scopeid 0x20<link>
        #IPV6 地址                       #掩码长度      #作用域, link 表示仅该接口有效
        ether 00:0c:29:93:fd:c8  txqueuelen 1000  (Ethernet)
        #网口接口的 MAC 地址        #传输队列长度     #接口类型
        RX packets 192442  bytes 23005768 (21.9 MiB)
        #表示此接口接收到的报文个数, 总字节数
        RX errors 0  dropped 3378  overruns 0  frame 0
        #接收报文错误数, 丢弃数, 溢出数(由于速度过快而丢失的数据包), 冲突的帧数
        TX packets 441431  bytes 34287197 (32.6 MiB)
        #表示此接口发送的报文个数, 总字节数
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        #发送报文错误数, 丢弃数, 溢出数(由于速度过快而丢失的数据包), 载荷数(发生 carrier 错误而丢失的数据包), 冲突的帧数

4.ethtool 解决网络丢包问题

  • 全双工与半双工(储备知识)
⛅全双工传输英文写法是:Full - Duplex Transmissions
是指交换机在发送数据的同时也能够接收数据,两者同步进行
这好像我们平时打电话一样,说话的同时也能够听到对方的声音, 目前的交换机都支持全双工。全双工的好处在于迟延小、冲突少、速度快

⛅半双工: 就是指一个时间段内只有一个动作发生,举个简单例子,一条窄窄的马路,同时只能有一辆车通过,当目前有两量车对开,这种情况下就只能一辆先过,等到头儿后另一辆再开
这个例子就形象的说明了半双工的原理
早期的对讲机、以及早期集线器等设备都是实行半双工的产品
随着技术的不断进步,半双工会逐渐退出历史舞台
  • CRC 校验(储备知识)
⛅CRC 即循环冗余校验码(Cyclic Redundancy Check) 
是数据通信领域中最常用的一种查错校验码,其特征是信息字段和校验字段的长度可以任意选定
循环冗余检查 (CRC) 是一种数据传输检错功能
对数据进行多项式计算,并将得到的结果附在帧的后面,接收设备也执行类似的算法,以保证数据传
输的正确性和完整性
  • 网卡工作原理(储备知识)
⛅网卡发包
1、"ip" 包 + 14 个字节的 "mac" 头变成数据帧 "frame"
2、"frame" 拷贝到网卡芯片内部的缓冲区,由网卡处理
3、网卡芯片为 "frame" 添加头部同步信息和 "CRC" 校验,此时才是真正可以发送的 "packet", 然后发送
该 "packet"

⛅网卡收包
1、网络包 "packet" 到达网卡,网卡先检查包 "packet" 的 "CRC" 校验,保证其完整性和正确性,然后去掉它的头得到 "frame"
2、网卡将 "frame" 拷贝到网卡内部的 "FIFO" 缓冲区
3、网卡驱动程序产生硬件中断,把 "frame" 从网卡拷贝到内存中,接下来就交给内核处理

⛅网卡丢包
1. 内核通常需要快速的拷贝网络数据包到系统内存
2. 因为网卡上接收网络数据包的缓存大小固定,而且相比系统内存也要小得多
3. 所以上述拷贝动作一旦被延迟,必然造成网卡 FIFO 缓存溢出 - 进入的数据包占满了网卡的缓存
4. 后续的包只能被丢弃,这也应该就是 "ifconfig" 里的 "overrun" 的来源。
  • 丢包问题解决
⛅丢包排查
网卡工作在数据链路层,数据量链路层,会做一些校验,封装成帧
我们可以查看校验是否出错,确定传输是否存在问题。然后从软件层面,是否因为缓冲区太小丢包

⛅先查看底层硬件情况
🌞查看工作模式是否正常
[root@shawn ~]#ethtool ens32 | egrep 'Speed|Duplex'
    Speed: 1000Mb/s
    Duplex: Full
🌞查看 CRC 校验是否正常
[root@shawn ~]#ethtool -S ens32 | grep crc
     rx_crc_errors: 0
#出现 Speed, Duplex, CRC 之类的都没问题,基本可以排除物理层面的干扰

⛅通过 "ifconfig" 可以看到 "overruns" 是否一直增大,如果查看结果是一直增大
🌞先查看网卡缓冲区
[root@shawn ~]#ethtool -g ens32
Ring parameters for ens32: 
Pre-set maximums:   #最大可设置的值
RX:     4096
RX Mini:    0
RX Jumbo:   0
TX:     4096
Current hardware settings:  #当前设置的值
RX:     256
RX Mini:    0
RX Jumbo:   0
TX:     256
🌞进行调大, 并再次查看
[root@shawn ~]#ethtool -G ens32 rx 2048  (增大)
[root@shawn ~]#ethtool -G ens32 tx 2048  (增大)
[root@shawn ~]#ethtool -g ens32
Ring parameters for ens32:
Pre-set maximums:
RX:     4096
RX Mini:    0
RX Jumbo:   0
TX:     4096
Current hardware settings:
RX:     2048     #可以发现变大了
RX Mini:    0
RX Jumbo:   0
TX:     2048

5.ethtool 网卡降速

[root@shawn ~]#ethtool -s ens32 speed 100 duplex full
[root@shawn ~]#ethtool -s ens32 speed 100 duplex full autoneg off  #关闭自适应才能设置成功
[root@shawn ~]#ethtool ens32   #查看

⛅若想完成永久设置,可以将上述 "ethtool" 设置写入 /"etc/rc.d/rc.local" 之中
🌞然后记住必须要加一个 x 权限
[root@shawn ~]# chmod +x /etc/rc.d/rc.local

6.ping 命令

⛅测试两台主机网络是否通
1. ping [目标 IP 地址]              #Ctrl + c 结束
2. ping -c [次数] [目标 IP 地址]    #设置 "ping" 的次数

⛅禁止别人 "ping" 自己
# echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all

7. 关闭 NetworkManager 服务

  • NetworkManager 是检测网络、自动连接网络的程序
  • 网络管理器最初由 Redhat 公司开发,现在由 GNOME 管理
  • 它会干扰网络配置, 比如: DNS 经常被刷掉, 所以通常关闭
[root@shawn ~]#systemctl stop NetworkManager       (关闭)
[root@shawn ~]#systemctl disable NetworkManager    (开机不重启)

8./etc/sysconfig/network-script/ifcfg-xxx配置文件相关信息

28 网络管理之网卡配置

28 网络管理之网卡配置

9.dns 配置文件

  • /etc/resolv.conf DNS 解析文件
⛅可以设置 DNS 指向, 最多三个
[root@shawn ~]#cat /etc/resolv.conf
nameserver 8.8.8.8             #对应的是网卡配置文件中的第一个 NDS 配置项
nameserver 223.6.6.6           #对应的是网卡配置文件中的第二个 NDS 配置项
  • /etc/hosts 本地名称解析文件, 优先于 DNS
⛅DNS 检索优先级
浏览器缓存 ---> 本地系统缓存 ---> 本地计算机 HOSTS 文件 --->ISP 远程 DNS---> 递归 or 迭代搜索

10. 永久设置主机名

⛅通过修改文件来永久修改主机名
[root@localhost ~]# vi /etc/hostname  

⛅通过命令的方式也是永久修改
[root@localhost ~]# hostnamectl set-hostname [想要的主机名]
[root@localhost ~]# exit
登出
⛅重新登入即可

11. 查看端口与服务的对应关系

[root@shawn ~]#grep '^ftp\|^ssh' /etc/services

28 网络管理之网卡配置

正文完
 
shawn
版权声明:本站原创文章,由 shawn 2023-06-16发表,共计5170字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(没有评论)